home *** CD-ROM | disk | FTP | other *** search
- #include "../CGVPMacro.csi"
-
- MainInput { uniform sampler2D baseMap : texunit0,
- uniform sampler2D bumpMap : texunit1,
- uniform samplerCUBE normCubeMapHA : texunit2,
- uniform float4 Specular }
- DeclarationsScript
- {
- OUT_T0_T1_T2
- FOUT
- }
- CoreScript
- {
- // load the decal
- float4 decalColor = tex2D(baseMap, IN.Tex0.xy);
- // load the bump normal
- float4 bumpNormal = 2*(tex2D(bumpMap, IN.Tex1.xy)-0.5);
-
- // Half angle vector from normalization cube-map
- float4 hVec = 2*(texCUBE(normCubeMapHA, IN.Tex2.xyz)-0.5);
-
- float NdotH = saturate(dot(hVec.xyz, bumpNormal.xyz));
- float specVal = saturate((NdotH - 0.75)*4);
- specVal = specVal * specVal;
- float3 spec = (specVal * Specular.xyz * decalColor.a) * 2;
-
- // finally add them all together
- OUT.Color.xyz = spec;
- OUT.Color.w = Specular.w;
- }
-
-